<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <script src="./vue.js"></script>
    <script>
      /*
        Vue实例(对象) -> vm
        - 属性
        - 方法
        - 事件、周期函数
      */
      const vm = new Vue({
        // data 配置项
        data: {
          username: "jack",
        },
        // 周期函数（根）当对象（new Vue）创建前执行
        beforeCreate() {
          console.log("beforeCreate", this.username);
        },
        // 周期函数（根）当对象（new Vue）创建完成后执行
        created() {
          setTimeout(() => {
            this.$destroy(); //销毁自己
          }, 3000);
          console.log("creared", this.username);
        },

        beforeDestroy() {
          console.log("beforeDestroy");
        },
        destroyed() {
          console.log("destroyed");
        },
        // methods 配置项
        methods: {
          say() {
            console.log(this.username);
          },
        },
      });
      //   vm.username = "jack";
      //   vm.say = function () {
      //     console.log(this.username);
      //   };
      vm.say();
      console.log(vm);

      // setTimeout(() => {
      //   vm.$destroy();//销毁自己
      // }, 3000);
    </script>
  </body>
</html>
